我所在的团队负责管理公司面向公众的云平台。我们拥有大量运行面向互联网的VM的用户群。我想对我们的地址空间进行自动扫描,看看是否有人在运行Rails应用程序,这样我就可以通知他们升级他们的Rails版本,以避免本周出现的严重安全漏洞。我注意到在某些Apache部署中,有一个有用的PassengerHeader:X-Powered-By:PhusionPassenger(mod_rails/mod_rack)2.0.3然而,这并不可靠。我想知道是否有一种可靠的方法来检测在Web服务器后面运行的Rails,无论是使用响应header还是某种可以确定的GET/POST。谢谢!
那是我的代码。现在我需要向主机发送一个cookie,但我找不到解决方案。defget_network_file(url=nil)beginhttp=Net::HTTP.new(@service_server,80)resp,data=http.get(url,{"Accept-Language"=>@locale})ifresp.code.to_i!=200RAILS_DEFAULT_LOGGER.error"***returncode!=200.code=#{resp.code}"return""endrescueException=>excRAILS_DEFAULT_LOGGER.
在我的Rails应用程序中,我有users,它可以有许多invoices,而invoices又可以有许多payments。现在在dashboardView中,我想总结一个user曾经收到的所有payments,按年、季度或月。付款也分割为毛额、Netty和税额。user.rb:classUser:items).allpayments_with_invoice.select{|x|range.cover?x.date}.sum(&:"#{kind}_amount")endend发票.rb:classInvoicepayment.rb:classPaymentdashboards_cont
我想显示一个计数中使用的SQL。但是,Model.count.to_sql将不起作用,因为count返回一个没有to_sql方法的FixNum。我认为最简单的解决方案是这样做:Model.where(nil).to_sql.sub(/SELECT.*FROM/,"SELECTCOUNT(*)FROM")这会创建与Model.count中使用的SQL相同的SQL,但它是否会导致进一步的问题?例如,如果我添加一个复杂的where子句和一些连接。有更好的方法吗? 最佳答案 你可以试试Model.select("count(*)asmode
我有一些巨大的文本文件需要处理并从数据中理解。部分任务是将此数据保存到数据库中。我想使用Ruby,postgres或mysql,postgres是首选。我应该包含哪些库?没有模型,它将是普通的SQL语句。如何在没有Rails的情况下做到这一点? 最佳答案 对于PostgreSQL,您需要ruby-pg.它为您的基本数据库连接提供查询它的能力。文档很少,但源代码树中有大量代码示例。这是一个相当简单的方法:https://bitbucket.org/ged/ruby-pg/src/e4465a9779faed39825213d140df
我正在尝试从URL解析XML文件。当我尝试这样的事情时:require'net/http'require'rubygems'require'xmlsimple'url='http://my-address.com/xmltest/note.xml'xml_data=Net::HTTP.get_response(URI.parse(url)).body一切正常,但仅当我在Rails项目之外执行此操作时。如果我尝试将此文件包含在我的Rails3项目中并在那里解析它,我会收到错误消息"Errno::ECONNREFUSEDin[controller]"-Connectionrefused-c
c:/ruby/lib/ruby/gems/1.8/gems/mechanize-1.0.0/lib/mechanize.rb:259:in`get':500=>Net::HTTPInternalServerError(Mechanize::ResponseCodeError)当我尝试导航到以下网页时出现上述错误http://fakewebsite.com//admin/edit_building.cfm?page=buildings&updateMode=yes&id=1251将链接复制并粘贴到浏览器时,我可以正常导航。注意:该网站确实需要登录,我使用如下代码处理$agent=Mec
我需要一些帮助来构建sql查询以在带有activerecord-postgis-adapter的rails中使用。我一直在阅读大量书籍,但现在有点卡住了,非常感谢任何帮助。我有两个模型Events和Areas:事件有一个点类型的“几何”列classEvent{:srid=>4326,:type=>"polygon",:geographic=>true}区域有一个“几何”列,类型为多边形classArea{:srid=>4326,:type=>"point",:geographic=>true}我可以在谷歌地图上创建和绘制事件和区域,并通过点击map并保存到数据库来创建区域。我希望能够执
我正在尝试使用Net::SCP为ssh连接定义一个自定义端口,但到目前为止运气不佳。下面是我如何尝试使用自定义ssh端口从服务器下载远程文件的示例:require"rubygems"require'net/scp'Net::SCP.download!("www.server.com","user","/opt/platform/upload/projects/file.txt","/tmp/bb.pdf",{:password=>"mypassword",:port=>22202})我得到的错误信息是:Errno::ECONNREFUSED:Connectionrefused-conn
使用下面的ftp_download方法是可行的,但是如果我改变ftp.getbinaryfile(file,localdir,1024)#=>Savesthefiletolocaldir到ftp.getbinaryfile(file)#=>returnsnil我得到nil返回。根据http://www.ruby-doc.org/stdlib-2.0/libdoc/net/ftp/rdoc/Net/FTP.html#method-i-getbinaryfileini如果我如上所述将localfile设置为nil,该方法应该检索并返回数据。我做错了什么?defftp_download(do